

**IN THE UNITED STATES PATENT AND TRADEMARK OFFICE**



Applicant: Steven Donald SPENCE, et al.

Title: SYSTEM AND METHOD FOR CLOCK SYNCHRONIZATION FOR USB SINK DEVICE

Appl. No.: To be assigned

Filing Date: July 20, 2001

Examiner: Unassigned

Art Unit: Unassigned

**CLAIM FOR CONVENTION PRIORITY**

Commissioner for Patents  
Washington, D.C. 20231

Sir:

The benefit of the filing date of the following prior foreign application filed in the following foreign country is hereby requested, and the right of priority provided in 35 U.S.C. § 119 is hereby claimed.

In support of this claim, filed herewith is a certified copy of said original foreign application:

- AUSTRALIA Patent Application No. PQ 8963/00 filed July 24, 2000.

Respectfully submitted,

Date July 20, 2001  
By Philip J. Artiola Reg. No.  
for David A. Blumenthal 78,819  
Attorney for Applicant  
Registration No. 26,257

FOLEY & LARDNER  
Washington Harbour  
3000 K Street, N.W., Suite 500  
Washington, D.C. 20007-5109  
Telephone: (202) 672-5407  
Facsimile: (202) 672-5399



Spence  
74273-192

11000 U.S. PTO  
09/09/99  
07/20/01

## CERTIFIED COPY OF PRIORITY DOCUMENT

Patent Office  
Canberra

I, LISA TREVERROW, TEAM LEADER EXAMINATION SUPPORT AND SALES hereby certify that annexed is a true copy of the Provisional specification in connection with Application No. PQ 8963 for a patent by NEC AUSTRALIA PTY LTD filed on 24 July 2000.



WITNESS my hand this  
Twenty-ninth day of November 2000

  
LISA TREVERROW  
TEAM LEADER EXAMINATION  
SUPPORT AND SALES

**NEC Australia Pty Ltd**

**A U S T R A L I A**  
**Patents Act 1990**

**PROVISIONAL SPECIFICATION**

for the invention entitled:

**"A Clock Synchronisation Method for USB Sink Devices"**

The invention is described in the following statement:

## A CLOCK SYNCHRONISATION METHOD FOR USB SINK DEVICES

The present invention relates to a clock synchronisation method and a system for executing the method. In particular, the invention relates to a method for a USB (Universal Serial Bus) data sink, using an isochronous endpoint, to adaptively synchronise its output clock rate to a USB data source input clock rate, without using feed back, or feed forward techniques or additional clock signals.

In a synchronous communication system having a data source and a data sink, the data output from the data sink is expected to be synchronous with the data input to the data source. When the data source and the data sink are connected using a USB, the data input clock is not synchronous to the USB clock, which does not allow the data output to be synchronised to the data input, even if the data output clock is synchronised to the USB clock. The difference between the input and output clocks leads to a frequency mismatch and subsequent data corruption.

Some systems, which do not require a high degree of data accuracy, could tolerate the frequency mismatch and data corruption. Typical low cost audio applications using a non synchronised USB audio source (e.g. CD) and USB audio sink (e.g. speakers) are not significantly degraded audibly, if audio samples are discarded or inserted to accommodate clock mismatch.

For real-time ISDN applications such as video, data loss due to clock frequency mismatch notably affects the quality of the service. It produces effects such as picture freezing and is much less tolerable.

Techniques, which can perform clock synchronisation between the data input clock and the USB clock, have limited application due to the fact that they can only synchronise the USB clock to a limited degree of accuracy.

For an application involving a mobile phone using a USB interface to access synchronous services via an ISDN interface, one possible synchronisation option is a method referred to as clock mastering for asynchronous source and synchronous sink. This involves the source device influencing a USB host's SOF (Start Of Frame) generation, so that

5 isochronous data transfer is synchronised to the source. The host SOF rate (1mS) is adjusted to track the mobile phone's data frame rate (10mS). An ISDN interface is a USB synchronous sink (i.e. locked to the SOF clock) and the frame transfer from the mobile phone to the ISDN interface is synchronised. The ISDN clock (i.e. I.430 192KHz bit clock) is synchronised to the SOF clock. The SOF adjustment resolution is 1/12000 bit times, where a bit period is one 12

10 MHz clock cycle or 83 ppm. Due to this coarse clock resolution, the source is not able to select a single optimum SOF period. The source clock of a mobile phone is locked to the mobile network and is very accurate with the result that the frequency error may approach 83 ppm. As this would still cause frame drift, so the source needs to continuously switch the SOF bit period up and down to achieve a synchronised average SOF period. The sink must then track

15 the average of the SOF period, as a step of 83 ppm (parts per million) is not acceptable. The I.430 interface imposes a clock accuracy requirement of better than  $\pm 100$  ppm and clock jitter must be significantly less. To overcome this it is necessary to integrate the frequency change with a period greater than the correction rate, so that the applied sink frequency correction is much more stable. An error of 83 ppm causes an I.430 frame slip approximately every 3

20 seconds, so a correction rate of 3 Hz and an integration period of 3 seconds is a possible solution.

Whilst clock mastering is feasible, it is less than desirable due to the coarse clock adjustment and the limitation that only one device may act as clock master. In a number of

25 applications this synchronisation method could not be used.

It is desired to provide another synchronisation option, which involves an asynchronous source and adaptive sink, and allows implicit feed forward clock recovery, or which at least provides a useful alternative.

In accordance with the present invention, there is provided a method for adaptive synchronisation of a data sink to a data source coupled by a USB, including the steps of:

receiving data for a buffer of said sink at an average data rate representative of the data rate of said source;

5 determining a data level for said buffer based on input packet size and output packet size;

comparing an accumulated data level for said buffer with a threshold level; and

correcting a clock frequency for said sink when said accumulated data level exceeds said threshold level.

10

Preferably said correcting step involves correcting the frequency by an amount equal to a constant K divided by the time required for the accumulated data level to drift from a reference level to the threshold level.

15

Preferably said method includes inhibiting said comparing and correcting step for a predetermined period after said correcting step. The predetermined period may be between three or five times said drift time. Preferably said predetermined period is reduced if said data level traverses said reference level or exceeds twice the threshold level.

20

Preferably the reference level is the data level measured over a first measurement period. Preferably said comparing step is executed periodically.

25

Preferably the threshold level is set to be greater than three times a maximum data level jitter. Preferably the size of the buffer is set to be greater than three times said threshold level.

Preferred embodiments of the present invention are hereinafter described, by way of example only, with reference to the accompanying drawings, wherein:

Figure 1 is a block diagram of a preferred embodiment of a data transfer system  
30 executing an adaptive clock synchronisation method;

Figure 2 is a graph of the level of data in a sink device of the system against time; and Figure 3 is a graph of the average sink data level against time.

A data transfer system, as shown in Figure 1, executes adaptive clock synchronisation  
 5 for data passed from a source device to a sink device using a USB, and a USB host that executes a USB host application. The host may be a PC with at least one USB port. The source device may be a mobile telephone and the sink device may be a computer with a video card or an interface to an ISDN, as described below. The source has a synchronous data flow rate  $DR_{source}$ , a source frequency  $F_{source}$ . The USB source to host average data flow rate  
 10 is  $DR_{usb1}$ , and the USB host to sink average data flow rate is  $DR_{usb2}$ . The host application preserves the data flow rate from the source connection to the sink connection such that  $DR_{usb1} = DR_{usb2} = DR_{usb}$ . The sink data flow rate is denoted  $DR_{sink}$  and the sink frequency is denoted  $F_{sink}$ . The sink device includes a rate adaption buffer which has an input stream received at  $DR_{usb1}$  and an output stream sent at the rate  $DR_{sink}$ . The sink device  
 15 includes circuit components to implement the buffer and execute the synchronisation method. For instance, the components may include a microprocessor and control software defining the synchronisation method.

The adaptive clock synchronisation method, as described in detail below, operates by  
 20 adjusting the sink data rate  $DR_{sink}$  to match the USB data delivery rate  $DR_{usb}$  by controlling the sink clock frequency  $F_{sink}$ . This results in synchronisation of the sink device with the source as the source data rate  $DR_{source}$  is implicit in the USB data delivery rate  $DR_{usb}$  when averaged over time.

25 The difference between the input and output data streams of the rate adaption buffer is detected by comparing the sink device data level (being input flow from the USB minus the output flow), with plus and minus threshold levels. The data level is checked periodically by the sink device and if the threshold is exceeded, then a frequency correction is determined based on the inverse of the time ( $T_{drift}$ ), taken for the data level to drift from a reference level  
 30 to the threshold level, as shown in Figure 3. The correction is set approximately 20% greater

than necessary, to ensure the drift is reversed and the frequency asymptotes towards the source frequency. Recorrection is inhibited for 5 times the drift period (*Tdrift*) or terminated early, if the data level crosses the reference level or 2 times the threshold level. These checks cater for error conditions should they arise. The reference level is determined when data transfer 5 commences.

The flow rate matching process results in frequency matching (*Fsource* to *Fsink*) to better than 100 ppm and typically better than 10ppm (this meets the requirements of BRI ISDN) and an elimination of data overrun or underrun, which occurs when source and sink 10 data rates are not matched.

Figure 2 shows how the level of data held in the rate adaption buffer of the sink device varies over time. In this example data is shown arriving in small roughly constant packet sizes (*Pi*) and being extracted at a fixed rate with a larger packet size (*Po*). The average data level 15 is an important factor for determining flow imbalance. The data level increase is greatly exaggerated for the purposes of this description. For an ISDN interface, a rate difference of 50 ppm will cause the level to change by 1 byte over about 1 second.

Figure 3 shows typical behaviour of the average data transfer level. Two clock 20 correction points are shown. The rate of drift is slowed at each correction. The overshoot shown at the correction point occurs due to the correction being applied gradually.

To execute the clock synchronisation method the system has:

1. A data source with a synchronous data flow rate, *DRsource*.
2.  $DR_{usb} = DR_{source}$ , when measured over sufficiently long period, to average out 25 the transport jitter.
3. All source data is transferred to the USB host. This may involve data repacketisation and data packets (*Pi*) with different size, but constant in time, between the USB frames.
- 30 4. A USB transport rate which is greater than the source data rate. The source data

- 7 -

delivery rate,  $DR_{usb}$  is not the same as the USB transport rate.  $DR_{usb}$  is the rate at which the USB system transports data provided by the source.

5 5. A host application which preserves the data flow rate from the source connection to the sink connection, such that  $DR_{usb1} = DR_{usb2} = DR_{usb}$ , as described above.

Figure 1 shows the source and sink both connected to the host by a USB, yet all that is required is the sink to receive data at a data delivery rate  $DR_{usb2}$  that implies the source rate  $DR_{source}$ .

10 The USB system introduces data transfer jitter (ie packet size ( $Pi$ ) variation) due to the phase shift between the source clock and the USB clock, and consequently output packet size ( $Po$ ) variation. The adaptive synchronisation method takes this into account, by buffering the data transfer and checking only for long term accumulation or depletion of data, passing through the sink, to determine data rate imbalance.

15 15. The data level variation over time, as shown in Figure 2, is a result of the combined effect of the following factors:

- (i)  $F_{sink}$  to  $F_{source}$  differences at start up (i.e. prior to clock correction);
- (ii) USB transport jitter; and
- (iii) Sink frequency jitter (arising from the synchronisation method).

20 25. As long as the rate adaption buffer is large enough to accommodate the fluctuation (i.e. does not overflow or underflow) the synchronous output data flow from the sink can be maintained uninterrupted. Balanced data flow requires the quantity of input data minus the quantity of output data to remain constant over time, such that:

- (a) If the data level increases then  $F_{source} > F_{sink}$  and  $F_{sink}$  must be increased; and
- (b) If the data level decreases then  $F_{sink} > F_{source}$  and  $F_{sink}$  must be decreased.

30 Data flow balance in the reverse direction occurs simultaneously as a result of synchronisation between transmit and receive clocks in both the source and sink.

As shown in Figure 2, the data level changes constantly. In order to determine if there is a flow imbalance (and hence a clock frequency difference), it is necessary to determine a trend in the data level changes. This is done by accumulating the data level changes, i.e. the sum of the data input flow minus the data output flow. The data input flow is the total size of 5 the packets received by the buffer and the data output flow is the total size of the packets output by the buffer.

The Accumulated Data Level (*ADL*) over a period of time ( $\Delta T$ ) is:

$$10 \quad ADL = Reference\_level + \sum_0^{\Delta T} (Data\_input - Data\_output) \quad (1)$$

15 i.e.  $ADL = Reference\_level + \Delta DL$

where

|    |                        |                                           |
|----|------------------------|-------------------------------------------|
| 20 | <i>Reference_level</i> | is the reference (or initial) data level  |
|    | <i>Data_input</i>      | is the data input flow, being $\sum P_i$  |
|    | <i>Data_output</i>     | is the data output flow, being $\sum P_o$ |
|    | <i>ΔDL</i>             | is the accumulated data level change      |

Only changes in the accumulated data level are of interest for clock correction , because the reference data level is constant.

25

The accumulated data level (*ADL*) varies due to:

- (i) The frequency difference between the source and sink; and
- (ii) Transport jitter due to the discrete nature of data inflow and outflow.

30 Thus the change in the Accumulated Data level can be defined also as,

$$\Delta DL = \sum (Freq\_difference\_level\_drift + Packet\_del/extr\_jitter)$$

- 9 -

(2)

where

5            *Freq\_difference\_level\_drift* is the data level change  
*Packet\_del/extr\_jitter*            is the jitter due to the source and sink data flow

The second factor, the jitter, causes an error in the measurement of the data level and in the calculation of the frequency correction required to achieve balance. To minimise the jitter influence, the USB data transfer packet size should be kept as small as possible and the  
10 data level measurement synchronised to the source or sink interface which delivers/retrieves data to/from the interface with greater packet size (*Pi* or *Po*).

Hereafter, the adaptive clock synchronisation method is described with reference to the USB sink being a BRI ISDN adaptor or interface and the USB source being a mobile phone.  
15 The mobile phone receives input data, such as a video data, in 10mS frames (80 bytes of data). When transported over the USB (as source data), the data frame is spread over nine 1mS isochronous USB frames (nominally 11 byte frames) and read by the sink device as 10mS frames (80 bytes). The data level measurement is synchronised to the data retrieval at the sink, resulting in a jitter of 11 bytes (a USB source packet). If the data level measurement is not  
20 synchronised, the potential jitter is 91 bytes (a USB source packet + a sink packet).

The first factor causing variations in the accumulated data level ( $\Delta DL$ ) is due to the source - sink frequency difference. The relationship of the *Freq\_difference\_level\_drift* to the frequency difference is derived as follows:

25

$$\Delta DL \propto F_{source} - F_{sink}$$

30

$$\Delta DL = K \times \int_0^{\Delta T} (F_{source} - F_{sink}) dt$$

$$\Delta DL = K \times \Delta T \times (F_{source} - F_{sink})$$

(3)

where

$\Delta T$  is the measurement period  
 $K$  is a system design constant

5

A frequency correction value ( $F_{corr}$ ) is equal to the frequency difference between the source and the sink frequencies ( $F_{source} - F_{sink}$ ) and is determined by rearranging Equation 3, setting the data level to a suitable error detection threshold and setting  $\Delta T$  to the time for the data level to drift from the reference level to the positive or negative threshold level, as 10 shown in Figure 3, such as:

$$F_{corr} = \text{Threshold\_level} / (K \times T_{drift}) \quad (4)$$

15 The frequency correction value is therefore determined by measuring the time taken for the data level to shift from the reference level to a threshold level. The key factor in doing this is to accurately determine the data level and its change. The method and an appropriate set of parameters for a given USB stream and an ISDN interface are described below.

20 The threshold level is the level which represents a significant/detectable change of the average buffer level. It should be:

- (i) As low as possible to minimise the rate adaption buffer size; and
- (ii) As high as possible to reduce the impact of jitter error on frequency correction accuracy.

25

Jitter may cause the threshold level to be exceeded earlier and the frequency correction value to be incorrectly calculated. A small  $T_{drift}$  measure produces an overcorrection, as the correction factor is inversely proportional (as shown in Equation 4). This is acceptable as long as the flow drift is reversed and the magnitude of the frequency error reduced, so that 30 successive corrections asymptote the error to zero. The level of overcorrection only impacts on the rate of convergence of the frequency error and does not effect data transfer quality.

- 11 -

Hence a maximum overcorrection due to jitter of 50% is recommended. This is comfortably below the 100% limit over which the sink frequency will diverge from the source frequency.

5 The threshold level, so that jitter does not cause an overcorrection greater than 50%, is determined from Equation 4 as follows:

$$\begin{aligned} F_{corr} &= \text{Threshold\_level} / (K \times T_{drift}) && \text{without jitter} \\ F_{corr\_j} &= \text{Threshold\_level} / (K \times T_{drift\_j}) && \text{with jitter} \end{aligned}$$

10 For a 50% overcorrection, i.e.  $F_{corr\_j} / F_{corr} = 1.5$   
 then  $T_{drift} / T_{drift\_j} = 1.5$  or  $T_{drift\_j} = 2/3 T_{drift}$

This occurs when the jitter level is 30% of the threshold level. Hence the threshold level must be at least 3 times the jitter level.

15 The data level is periodically compared (at each monitoring period) with the threshold level to minimise processing requirements.

20 For the ISDN example the USB packet size is nominally 11 bytes, the maximum jitter error is 11 bytes, the threshold level =  $3 \times 11 = 33$  bytes, and the monitoring period = 1 second.

The data level change due to a maximum frequency error of 100 ppm over 1 second = 1.25 bytes (based on Equation 5). The correction response is not effected by a one second monitoring period.

25 Clock correction is undertaken when the accumulated data level change ( $\Delta DL$ ) becomes equal or exceeds (in absolute terms) the threshold level. A frequency correction value  $F_{corr}$  is determined, the sink clock  $F_{sink}$  is adjusted by  $F_{corr}$  and further correction inhibited for a period to allow the data level to asymptote back towards the reference level.

The correction value  $F_{corr}$  is increased by 20 % over that derived from Equation 4 to accommodate calculation error and ensure the flow imbalance is reversed. The overcorrection factor is implementation dependent. It must exceed any calculation error resulting from the implementation but should not exceed 100% minus the overcorrection which results due to

5 data level jitter. The synchronisation method asymptotes the sink frequency  $F_{sink}$  to a value, which slowly hunts between a slightly high and slightly low frequency about the actual source frequency  $F_{source}$ . This is also done to accommodate the limitations in clock setting resolution. The method operates through the use of the  $\pm$  threshold levels and a minimum correction value.

10

For the ISDN example, the minimum adjustment is  $\pm 1$  ppm. Note also the maximum correction is also limited to  $\pm 100$  ppm to comply with I.430 requirements.

15 The sink clock frequency adjustment rate is limited to provide an acceptable output clock jitter. For the ISDN example the adjustment rate is restricted to 1 ppm per 10mS.

The correction inhibit period is employed to give time for the correction to take effect. This is needed because:

20 (a) Jitter will cause the data level value to recross the threshold until the average data level falls below the threshold minus the maximum jitter;

(b) The limited clock adjustment rate may cause the data level to increase further before the full correction takes place; and

(c) The flow imbalance, though reversed by the correction, is reduced in magnitude and may require considerable time for the data level to reduce from the threshold 25 level to the reference level.

30 The inhibit period is set to between 3x and 5x  $T_{drift}$  and terminated immediately if the reference level or twice the threshold level is crossed. The factor of 5 results from the frequency correction being nominally overcorrected by 20%. Thus the time for the data level to reduce back to the reference level is  $T_{drift}/0.2$ . The factor may be as low as 3x as this will

- 13 -

still ensure the data level has decreased to a level less than 1/2 the threshold and jitter will not cause false recorrection. The termination conditions are included to accommodate the additional overcorrection due to jitter and further change of the source frequency  $F_{source}$ .

5 The factor  $K$  in Equation 3 is determined by setting  $\Delta T$ , ( $F_{source} - F_{sink}$ ) and  $\Delta DL$  to known values for the application. For a 64 Kbps data stream, 1 byte of data is transmitted every  $125\mu\text{S}$ . If the frequency error ( $F_{source} - F_{sink}$ ) is 1 ppm, the data level will increase by 1 byte in  $125\mu\text{S}/10^{-6} = 125$  seconds. So by setting  $\Delta T = 125$  in Equation 3,

10 
$$K = \Delta DL / (\Delta T \times (F_{source} - F_{sink})) = 1/(125 \times 1) = 1/125 \text{ s}^{-1} \text{ ppm}^{-1}$$

Equation 4 becomes:

15 
$$F_{corr} = 125 \times \text{Threshold} / T_{drift} \quad \text{ppm} \quad (5)$$

where  $T_{drift}$  has units of seconds.

For the ISDN example the sink clock is implemented as a VCO controlled by a DAC  
20 output from a microprocessor that monitors the rate adaption buffer and executes the synchronisation method to determine  $F_{corr}$ . The VCO has a  $\pm 2\text{V}$  input range to adjust the frequency  $\pm 100$  ppm. So for a 5V DAC range, 1 bit adjusts the frequency 0.98 ppm. Including the 20% overcorrection, the constant  $K$  becomes 153.6 ( $= 125 \times 1.2 / 0.98$ ) and the DAC output correction value ( $DAC_{out}$ )

25

$$DAC_{out} = 153.6 \times \text{Threshold} / T_{drift} \quad \text{bits/ppm}$$

- 14 -

Many modifications will be apparent to those skilled in the art without departing from the scope of the present invention as hereinbefore described with reference to the accompanying drawings.

5

DATED this 24<sup>th</sup> day of July 2000

10

**NEC Australia Pty Ltd**  
By its Patent Attorneys  
**DAVIES COLLISON CAVE**



Figure 1



Figure 2